package org.dromara.datacheck.service.jst;

import org.dromara.common.mybatis.core.page.PageQuery;
import org.dromara.common.mybatis.core.page.TableDataInfo;
import org.dromara.datacheck.domain.bo.JstAndJDTableDataEntryBo;
import org.dromara.datacheck.domain.bo.jst.JstAfterSaleOrderBo;
import org.dromara.datacheck.domain.jst.JstAfterSaleOrder;
import org.dromara.datacheck.domain.vo.jst.JstAfterSaleOrderVo;

import java.util.Collection;
import java.util.List;

/**
 * 聚水潭-售后单Service接口
 *
 * @author 刘武贵
 * @date 2024-09-08
 */
public interface IJstAfterSaleOrderService {

    /**
     * 查询聚水潭-售后单
     *
     * @param id 主键
     * @return 聚水潭-售后单
     */
    JstAfterSaleOrderVo queryById(Long id);

    /**
     * 分页查询聚水潭-售后单列表
     *
     * @param bo        查询条件
     * @param pageQuery 分页参数
     * @return 聚水潭-售后单分页列表
     */
    TableDataInfo<JstAfterSaleOrderVo> queryPageList(JstAfterSaleOrderBo bo, PageQuery pageQuery);

    /**
     * 查询符合条件的聚水潭-售后单列表
     *
     * @param bo 查询条件
     * @return 聚水潭-售后单列表
     */
    List<JstAfterSaleOrderVo> queryList(JstAfterSaleOrderBo bo);

    /**
     * 新增聚水潭-售后单
     *
     * @param bo 聚水潭-售后单
     * @return 是否新增成功
     */
    Boolean insertByBo(JstAfterSaleOrderBo bo);

    /**
     * 修改聚水潭-售后单
     *
     * @param bo 聚水潭-售后单
     * @return 是否修改成功
     */
    Boolean updateByBo(JstAfterSaleOrderBo bo);

    /**
     * 校验并批量删除聚水潭-售后单信息
     *
     * @param ids     待删除的主键集合
     * @param isValid 是否进行有效性校验
     * @return 是否删除成功
     */
    Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);

    /**
     * 查询聚水潭-售后单列表所有数据
     *
     * @return 聚水潭-售后单列表
     */
    List<JstAfterSaleOrder> queryAll();

    /**
     * 清空聚水潭-售后单列表所有数据
     *
     * @return 聚水潭-售后单列表
     */
    Integer deleteAll();

    /**
     * 查询聚水潭-售后单列表
     * 场景分类：寄售-寄售换货-售后单(猫超售后店铺，进口猫超售后店铺)
     * 业务查询条件：根据shop_name店铺名称为天猫超市-售后店铺、天猫进口超市-售后店铺并且after_sale_type类型为换货询
     */
    TableDataInfo<JstAfterSaleOrderVo> queryPageListShopName1(JstAfterSaleOrderBo bo, PageQuery pageQuery);

    /**
     * 查询聚水潭-售后单列表
     * 场景分类：2C销售-销售退货（售后单）
     * 业务查询条件：根据shop_name店铺名称除了猫超寄售售后、进口超市售后的店铺并且after_sale_type类型为退货询
     */
    TableDataInfo<JstAfterSaleOrderVo> queryPageListShopName2(JstAfterSaleOrderBo bo, PageQuery pageQuery);

    /**
     * 查询聚水潭-售后单列表以及金蝶-销售退货单数据汇总（按日期汇总）
     */
    TableDataInfo<JstAndJDTableDataEntryBo> jstAndJdSumByDateByConsignmentAfterSaleOrder();
}
